package com.wocao.entity;

import com.alibaba.excel.annotation.ExcelIgnore;
import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.annotation.write.style.ColumnWidth;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.*;

import java.io.Serializable;
import java.time.LocalDateTime;

import lombok.Data;

/**
 * 角色信息表
 */
@Data
@AllArgsConstructor
@NoArgsConstructor
@ToString
@TableName("sys_role")
public class SysRole implements Serializable {

    private static final long serialVersionUID = 1L;

    /**
     * 角色ID
     */
//    @ExcelIgnore
    @ExcelProperty("编码")
//    @ColumnWidth()
    @TableId(value = "role_id", type = IdType.AUTO)
    private Long roleId;

    /**
     * 角色名称
     */
    @ExcelProperty("角色名称")
    private String roleName;

    /**
     * 角色权限字符串
     */
    @ExcelProperty("权限字符")
    private String roleKey;

    /**
     * 显示顺序
     */
    @ExcelProperty("顺序")
    private Long roleSort;

    /**
     * 数据范围（1：全部数据权限 2：自定数据权限 3：本部门数据权限 4：本部门及以下数据权限）
     */
    @ExcelProperty("数据范围")
    private String dataScope;

    /**
     * 菜单树选择项是否关联显示
     */
    @ExcelProperty("菜单树是否关联")
    private Long menuCheckStrictly;

    /**
     * 部门树选择项是否关联显示
     */
    @ExcelProperty("部门树是否关联")
    private Long deptCheckStrictly;

    /**
     * 角色状态（0正常 1停用）
     */
    @ExcelProperty("角色状态")
    private String status;

    /**
     * 删除标志（0代表存在 2代表删除）
     */
    @ExcelProperty("删除标志")
    private String delFlag;

    /**
     * 创建者
     */
    @ExcelProperty("创建者")
    private String createBy;

    /**
     * 创建时间
     */
    @ExcelProperty("创建时间")
    @ColumnWidth(20)
    @JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
    private LocalDateTime createTime;

    /**
     * 更新者
     */
    @ExcelProperty("更新者")
    private String updateBy;

    /**
     * 更新时间
     */
    @ColumnWidth(20)
    @ExcelProperty("更新时间")
    private LocalDateTime updateTime;

    /**
     * 备注
     */
    @ExcelProperty("备注")
    private String remark;
}
